/*
* Copyright (c) 2025 Huawei Device Co., Ltd.
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including but not limited to the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to provide persons with access to the Software
* subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in all
* copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGE OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
* SOFTWARE.
*/

import React, { Component, ReactElement } from 'react';
import DetailsHeader from '../../components/DetailsHeader';
import DetailsChart from '../../components/DetailsChart';
import DetailsList from '../../components/DetailsList';
import { withStore } from '../../utils/functionProcess';
import './index.css';

class Details extends Component {
  state = {
    newListData: [
      { id: 1, name: 'Mate 60 Pro+', imgSrc: './img/classify_product_1.png' },
      { id: 2, name: 'Mate 60', imgSrc: './img/classify_product_2.png' },
      { id: 3, name: 'Mate 60 Pro', imgSrc: './img/classify_product_3.png' },
      { id: 4, name: 'Mate X5', imgSrc: './img/classify_product_4.png' },
    ],
    mateListData: [
      { id: 1, name: 'Mate 60 Pro+', imgSrc: './img/classify_product_1.png' },
      { id: 2, name: 'Mate 60', imgSrc: './img/classify_product_2.png' },
      { id: 3, name: 'Mate 60 Pro', imgSrc: './img/classify_product_3.png' },
      { id: 4, name: 'Mate X5', imgSrc: './img/classify_product_4.png' },
      { id: 5, name: 'Mate X3', imgSrc: './img/classify_product_5.png' },
      { id: 6, name: 'Mate 50', imgSrc: './img/classify_product_6.png' },
      { id: 7, name: 'Mate 50 Pro', imgSrc: './img/classify_product_7.png' },
      { id: 8, name: 'Mate Xs 2', imgSrc: './img/classify_product_8.png' },
      { id: 9, name: 'Mate 50E', imgSrc: './img/classify_product_9.png' },
      { id: 10, name: 'Mate 50 RS', imgSrc: './img/classify_product_10.png' },
    ],
    puraListData: [
      { id: 1, name: 'P60', imgSrc: './img/classify_product_11.png' },
      { id: 2, name: 'P60 Pro', imgSrc: './img/classify_product_12.png' },
      { id: 3, name: 'P60 Art', imgSrc: './img/classify_product_13.png' },
      { id: 4, name: 'P50 Pro', imgSrc: './img/classify_product_14.png' },
      { id: 5, name: 'P50E', imgSrc: './img/classify_product_15.png' },
      { id: 6, name: 'P50 Pocket', imgSrc: './img/classify_product_16.png' },
    ],
    newListTitle: '新品上市',
    mateListTitle: 'HUAWEI Mate系列',
    puraListTitle: 'HUAWEI P系列',
  };

  render(): ReactElement {
    const { newListData, mateListData, puraListData, newListTitle, mateListTitle, puraListTitle } = this.state;
    return (
      <div className='details-page' style={{ paddingTop: (this.props as any).store.topAvoidArea }}>
        <div className='details-header-area'>
          <DetailsHeader></DetailsHeader>
        </div>
        <div className='details-chart-area'>
          <DetailsChart></DetailsChart>
        </div>
        <div className='details-list-area'>
          <DetailsList details-list-data={newListData}
                       details-list-title={newListTitle}></DetailsList>
          <DetailsList details-list-data={mateListData}
                       details-list-title={mateListTitle}></DetailsList>
          <DetailsList details-list-data={puraListData}
                       details-list-title={puraListTitle}></DetailsList>
        </div>
      </div>
    );
  }
}

export default withStore(Details);